<template>
  <a-card :bordered="false">
    <a-form ref="searchFormRef" name="advanced_search" :model="searchFormState" class="ant-advanced-search-form">
      <a-row :gutter="24">
        <a-col :span="6">
          <a-form-item label="存酒水ID" name="beverageId">
            <a-input v-model:value="searchFormState.beverageId" placeholder="请输入存酒水ID" />
          </a-form-item>
        </a-col>
        <a-col :span="6">
          <a-form-item label="业务类型 1 酒水存储 2 酒水取出" name="businessType">
            <a-input v-model:value="searchFormState.businessType" placeholder="请输入业务类型 1 酒水存储 2 酒水取出" />
          </a-form-item>
        </a-col>
        <a-col :span="6">
          <a-button type="primary" @click="table.refresh(true)">查询</a-button>
          <a-button style="margin: 0 8px" @click="reset">重置</a-button>
        </a-col>
      </a-row>
    </a-form>
    <s-table ref="table" :columns="columns" :data="loadData" :alert="options.alert.show" bordered
      :row-key="(record) => record.id" :tool-config="toolConfig" :row-selection="options.rowSelection">
      <template #operator class="table-operator">
        <a-space>
          <a-button type="primary" @click="formRef.onOpen()" v-if="hasPerm('bizBeverageInfoAdd')">
            <template #icon><plus-outlined /></template>
            新增
          </a-button>
          <xn-batch-delete v-if="hasPerm('bizBeverageInfoBatchDelete')" :selectedRowKeys="selectedRowKeys"
            @batchDelete="deleteBatchBizBeverageInfo" />
        </a-space>
      </template>
      <template #bodyCell="{ column, record }">
        <template v-if="column.dataIndex === 'action'">
          <a-space>
            <a @click="formRef.onOpen(record)" v-if="hasPerm('bizBeverageInfoEdit')">编辑</a>
            <a-divider type="vertical" v-if="hasPerm(['bizBeverageInfoEdit', 'bizBeverageInfoDelete'], 'and')" />
            <a-popconfirm title="确定要删除吗？" @confirm="deleteBizBeverageInfo(record)">
              <a-button type="link" danger size="small" v-if="hasPerm('bizBeverageInfoDelete')">删除</a-button>
            </a-popconfirm>
          </a-space>
        </template>
      </template>
    </s-table>
  </a-card>
  <Form ref="formRef" @successful="table.refresh(true)" />
</template>

<script setup name="beverageinfo">
import Form from './form.vue'
import bizBeverageInfoApi from '@/api/biz/bizBeverageInfoApi'
let searchFormState = reactive({})
const searchFormRef = ref()
const table = ref()
const formRef = ref()
const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
const columns = [
  {
    title: '存酒水ID',
    dataIndex: 'beverageId'
  },
  {
    title: '业务类型 1 酒水存储 2 酒水取出',
    dataIndex: 'businessType'
  },
  {
    title: '备注',
    dataIndex: 'remark'
  },
]
// 操作栏通过权限判断是否显示
if (hasPerm(['bizBeverageInfoEdit', 'bizBeverageInfoDelete'])) {
  columns.push({
    title: '操作',
    dataIndex: 'action',
    align: 'center',
    width: '150px'
  })
}
const selectedRowKeys = ref([])
// 列表选择配置
const options = {
  // columns数字类型字段加入 needTotal: true 可以勾选自动算账
  alert: {
    show: true,
    clear: () => {
      selectedRowKeys.value = ref([])
    }
  },
  rowSelection: {
    onChange: (selectedRowKey, selectedRows) => {
      selectedRowKeys.value = selectedRowKey
    }
  }
}
const loadData = (parameter) => {
  const searchFormParam = JSON.parse(JSON.stringify(searchFormState))
  return bizBeverageInfoApi.bizBeverageInfoPage(Object.assign(parameter, searchFormParam)).then((data) => {
    return data
  })
}
// 重置
const reset = () => {
  searchFormRef.value.resetFields()
  table.value.refresh(true)
}
// 删除
const deleteBizBeverageInfo = (record) => {
  let params = [
    {
      id: record.id
    }
  ]
  bizBeverageInfoApi.bizBeverageInfoDelete(params).then(() => {
    table.value.refresh(true)
  })
}
// 批量删除
const deleteBatchBizBeverageInfo = (params) => {
  bizBeverageInfoApi.bizBeverageInfoDelete(params).then(() => {
    table.value.clearRefreshSelected()
  })
}
</script>
